# **Programming Assignment 2:**

# **Timing Analyzer with False Path Detection** (Due: 11/20)

#### **Problem Descriptions:**

Given a gate-level netlist and a cell library, implement the three steps below to show the longest delay time and their corresponding paths under a given input pattern.

### **Delay Calculation:**

Step1: Build the delay graph according to the given netlist

Step2: Calculate the delay and value of each node in the graph following topological order

Step3: Output the longest and delay and their corresponding paths

#### **Input Format:**

## 1. Flattened gate-level Verilog netlist

This file follows the standard Verilog gate-level syntax. In order to simplify the problem, the given netlist is flattened, i.e., only one module exists in the file. Only three kinds of cells (NAND2, NOR2, Inverter) will appear in this file. Sequential circuits are not necessary to be considered. However, your program should be able to deal with extra space (or TAB), extra new lines, and the comment lines starting with double slash (//). Below is a simple example. Please be noted that the delay values in this example are just assumptions to simplify the calculation. Actual delay should be obtained from the given library information.



Figure 1: An example of the gate-level netlist and its corresponding descriptions.

#### 2. Input patterns

This file gives the values of each input. The first line gives the name and order of each input. Input patterns are given in the following lines. Each pattern is given at separate line. Below is a simple example for the netlist in Figure 1.

#### 3. Simplified .LIB file

This file is simplified from the standard .LIB format [1], which collects the timing and power information for each cell. In order to simplify the problem, we assume that the timing and power information of the same output is the same for all input path, i.e., A1->ZN and A2->ZN have exactly the same delay and power. Therefore, only one table is recorded for each output. The table index is defined in **lu\_table\_template**. The two indexes are total output loading and input transition time. The default units are also given in the file, which are ns (timing), pF (capacitance), V (voltage), and mA (current). Please be noted that the total output loading and input transition time should be calculated based on the real circuit connection. The input capacitance of a cell is the output loading of the preceding cell. The output rising/falling time of a cell will be the input transition time of the succeeding cells. Below is a simple example for the library information of an inverter. For simplicity, the numbers in this example may not be exactly the same as in the given library file.

```
lu_table_template(table10){
   variable_1: total_output_net_capacitance;
   variable_2 : input_transition_time;
   index_1 ("0.0014,0.0030,0.0062,0.0125,0.0251,0.0504,0.1010");
   index_2 ("0.0208,0.0336,0.0600,0.1112,0.2136,0.4192,0.8304");
cell (INVX1) {
  pin(I) {
         direction: input:
       capacitance: 0.0109;
  pin(ZN) {
              direction: output;
      capacitance: 0.0;
      internal power() {
          rise power(table10) { // internal power when output is rising
             value("0.0066,0.0090,0.0091,0.0094,0.0112,0.0147,0.0221",\
     "0.0023,0.0012,0.0084,0.0098,0.0107,0.0146,0.0224",\
     "0.0059,0.0089,0.0055,0.0094,0.0112,0.0138,0.0215",\
     "0.0098,0.0133,0.0067,0.0074,0.0118,0.0139,0.0199",\
     "0.0093,0.0038,0.0016,0.0059,0.0100,0.0131,0.0187",\
     "0.0076,0.0065,0.0062,0.0059,0.0015,0.0130,0.0168",\
     "0.0075,0.0059,0.0048,0.0019,0.0000,0.0000,0.0192");
     }
                                 // internal power when output is falling
          fall_power(table10)
             value(...);
                        // values are omitted in this example
            // end internal power
      timing() {
          cell rise(table10) {
                               // cell delay when output is rising
             value("0.0134,0.0160,0.0199,0.0225,0.0317,0.0402,0.0504",\
     "0.0153,0.0184,0.0230,0.0261,0.0371,0.0474,0.0599",\
     "0.0189,0.0224,0.0281,0.0326,0.0458,0.0599,0.0766",\
     "0.0260,0.0293,0.0330,0.0426,0.0545,0.0800,0.1039",\
```

```
"0.0400.0.0405.0.0458.0.0581.0.0764.0.0993.0.1468".\
 "0.0663,0.0686,0.0733,0.0837,0.1082,0.1440,0.1890",\
 "0.1222,0.1244,0.1292,0.1386,0.1595,0.2086,0.2792");
       cell fall(table10)
                            // cell delay when output is falling
                      // values are omitted in this example
          value(...);
       rise transition(table10)
                                 // output rising time
                      // values are omitted in this example
          value(...);
      fall_transition(table10)
                               // output falling time
          value(...);
                      // values are omitted in this example
        // end timing
   // end pin
// end cell
```

#### **Output Format:**

Before finding the worst-case delay path for the whole circuit, you have to determine the delay and transition time of each instance based on the circuit connection (step 2) and given input patterns. In order to verify the results of step 2, please also report the output value and timing information of each instance in the following format. Each row shows an instance name, its output value, its corresponding worst-case delay, and its output transition time in order. Since you have the logic value of each input line, do remember to determine the delay of each instance based on path sensitization. Please sort your results by the instance name.

```
g1 1 0.0160\ 0.0074 // output=1, propagation delay=0.0160, output rising time = 0.0074 g2 0 0.0107 0.0048 // output=0, propagation delay=0.0107, output falling time = 0.0048 g3 0 0.0215 0.0093 ......
```

According to this delay information, the **longest sensitizable path** of each input pattern is reported in different lines. Take Figure 1 as an example, 3 paths are reported as below for 3 different input patterns. Please be noted that it is only an example to explain the format. The paths and delay values may not be correct. In order to simplify the results, only net names are required to be reported. Instance name is not required.

```
Input 1 -> n4 -> n6 -> n10 -> n13 (delay = 15)
Input 1 -> n4 -> n6 -> n9 -> n12 (delay = 14)
Input 2 -> n6 -> n10 -> n13 (delay = 12)
```

#### **Requirement:**

The program must be able to receive commands in following format (a.out can be replaced by the name of your execution file). You must **output the longest delays and their corresponding sensitizable paths** based on the given library file *testlib.lib*. If there are more than one input patterns, please report the delay and path of each input pattern separately in different lines. And also **output the output value and timing information of each instance** into a separate file for verification.

```
% a.out netlist_file -p input.pat -l testlib.lib
```

For the boundary conditions, please set the input transition time of each primary input as **zero**, and set the output loading of each primary output as **0.03 pF**. Then, the delay time of each instance can be determined by the <u>input transition time</u> (the output transition time of its driving cell) and the <u>output loading</u> (the total input capacitance for all fanout gates) according to the given delay table. In order to simplify the problem, there are several assumptions while calculating the worst-case delay as listed below.

- 1. While calculating the output value of each instance, assume it is in zero-delay mode. In other words, please **ignore the glitch** during logic transition and use the final value directly. You can get the input values from the outputs of your driving gates.
- 2. If there are multiple paths from cell inputs to cell output, please use the sensitization rules to find the sensitizable path and use it to determine the delay value.
- 3. For each sensitizable path, there are two tables (*cell\_rise*, *cell\_fall*) for the delay time when output is rising or falling. If the output value of this cell is 1, we use the table (*cell\_rise*); otherwise, we use the table (*cell\_fall*).
- 4. As to the output transition time, there are also two tables (*rise\_transition*, fall\_transition) for the transition time when output is rising or falling. If the output value of this cell is 1, we use the table (*rise\_transition*); otherwise, we use the table (fall\_transition). This value is used the input transition time of the successor cells.

Your grade depends on the correctness and runtime of your program. If several students generate correct delay values successfully, their grades are determined based on the ascending order of run time. Please compress all the source code, the output files for the benchmarks, and a simple report explaining the implementation details, how to compile your program, and your comments to a compressed file. Then submit it to New E3 system before the deadline.

#### **Reference:**

1. Synopsys Liberty format, <a href="https://www.cic.org.tw/CommonUtilServlet?type=2.4&file=1162.pdf">https://www.cic.org.tw/CommonUtilServlet?type=2.4&file=1162.pdf</a>